# **Latches and Flip-flops**

CS207 Chapter 6

James YU yujq3@sustech.edu.cn

Department of Computer Science and Engineering Southern University of Science and Technology

Jul. 5, 2021





- Logic circuits for digital systems:
  - combinational logic (previous lectures),
  - sequential logic.
- Combinational?
  - Output determined by the combination of inputs.
  - Perform an operation specified by a set (combination) of Boolean functions.



- Almost all electronic consumer products
  - send, receive, store, retrieve, and process information
  - depends on the ability to store binary has memory.
- Sequential circuits
  - act as storage elements.
- The logic circuits whose outputs at any instant of time depend on the present inputs as well as on the past outputs are called sequential circuits.



- The logic circuits whose outputs at any instant of time depend on the **present** inputs as well as on the **past outputs** are called *sequential circuits*.
- A combinational circuit, but with
  - memory elements connected in a feedback path.
  - Outputs are binary functions of not only inputs, but also the present state of the circuit
  - A memory element is a medium in which one bit of information (0 or 1) can be stored or retained until necessary, and thereafter its contents can be replaced by a new value.





- Sequential circuits are broadly classified into two main categories, known as
  - synchronous or clocked sequential circuits, and
  - asynchronous or unclocked sequential circuits,
  - depending on the timing of their signals.
- A sequential circuit whose behavior can be defined from the knowledge of its signal at discrete instants of time is referred to as a synchronous sequential circuit.
  - The synchronization is achieved by a timing device known as a system clock.
  - The outputs are affected only with the application of a clock pulse.
- A sequential circuit whose behavior **depends upon the sequence in which the input signals change** is referred to as an asynchronous sequential circuit.



- A sequential circuit whose behavior can be defined from the knowledge of its signal at discrete instants of time is referred to as a synchronous sequential circuit.
  - The synchronization is achieved by a timing device known as a system clock.
  - The outputs are affected only with the application of a clock pulse.
- Clock pulse: when changes will happen; Other signals: what changes will happen.
- Clocked sequential circuits:
  - Synchronous sequential circuits that use clock to control.
  - Synchronous because the circuit activity and the updating of storage are synchronized.



- Memory element: *flip-flop*.
  - A binary storage device storing one bit;
  - Change in state happens only during clock pulse transition;
  - Loop cut when clock is inactive, no update.



### Flip-flops



- It can have only two states, either the 1 state or the 0 state.
- The general block diagram representation of a flip-flop is shown below:
  - It has one or more inputs and two outputs.
  - The two outputs are complementary to each other.



• Normally, the state of Q is called the *state* of the flip-flop, whereas the state of Q' is called the *complementary state* of the flip-flop.

### Flip-flops



- There has always been considerable confusion over the use of the terms <u>latch</u> and <u>flip-flop</u>.
  - A *flip-flop* is a device which changes its state at times when a change is taking place in the clock signal.
  - An <u>asynchronous latch</u> is continuously monitoring the input signals and changes its state at times when an input signal is changing.
  - A *synchronous latch* is continuously monitoring the input signals, but only can changes its state when a control signal is active.



#### **SR latches**



- By cross coupling a pair of NOR gates, we have a first latch: SR latch.
  - The set and reset inputs are labelled S and R respectively.



• The state table of SR latch is shown below

| Present |       |       | Next      |
|---------|-------|-------|-----------|
| $S_t$   | $R_t$ | $Q_t$ | $Q_{t+1}$ |
| 0       | 0     | 0     | 0         |
| 0       | 0     | 1     | 1         |
| 0       | 1     | 0     | 0         |
| 0       | 1     | 1     | 0         |
| 1       | 0     | 0     | 1         |
| 1       | 0     | 1     | 1         |
| 1       | 1     | For   | bidden    |

#### **SR latches**



• From the k-map:  $Q_{t+1} = S + R'Q$ .





• A more conventional form:



#### **Controlled SR latch**



- The transparency of SR latches can be controlled by an additional signal *G*:
  - If G=0, the outputs of first-level NAND gates are always 1, disabling any changes in the second level gates.
  - If G makes a transition from  $\emptyset$  to 1, the first-level NAND gates are enabled, making the latch active.



• A problem with SR latches: **state is indeterminate when** S **and** R **are both 1.** 

#### **Controlled D latch**



- D latch is designed to handle this problem.
  - Also called *transparent latch*, D for data.
  - Ensure the previous S and R are never equal to 1 at the same time.



| Pres             | sent  | Next                 |
|------------------|-------|----------------------|
| $\overline{D_t}$ | $Q_t$ | $\overline{Q_{t+1}}$ |
| 0                | 0     | 0                    |
| 0                | 1     | 0                    |
| 1                | 0     | 1                    |
| 1                | 1     | 1                    |

#### **Controlled D latch**



- The controlled D latch has the advantage that it only requires one data input and there is no input condition that has to be avoided.
- Transparent?
  - Data input is transferred to Q output when enable is asserted. The output follows the input.
  - When enable is de-asserted, the information is stored.

#### **Latches**





#### Flip-flops



- Latch or flip-flop state change by a control input.
  - The event is called trigger.
- When latches are memories, difficulty arises:
  - State changes as soon as clock switches to 1.
  - Infinite loop during clock-1.





- Latch circuits are not suitable for operation in synchronous sequential circuits because of their transparency.
  - Flip-flops are used as the basic memory elements, which only respond to a transition on a clock input.
  - A typical example is called JK flip-flop (JKFF).



| F                | rese  | Next  |                      |
|------------------|-------|-------|----------------------|
| $\overline{J_t}$ | $K_t$ | $Q_t$ | $\overline{Q_{t+1}}$ |
| 0                | 0     | 0     | 0                    |
| 0                | 0     | 1     | 1                    |
| 0                | 1     | 0     | 0                    |
| 0                | 1     | 1     | 0                    |
| 1                | 0     | 0     | 1                    |
| 1                | 0     | 1     | 1                    |
| 1                | 1     | 0     | 1                    |
| 1                | 1     | 1     | 0                    |



- J is S, and K is R.
- When J = K = 1, the flip-flop **toggles**.
- Combining the two AND gates with the SR latch circuit, we have the following reduced circuit:



- However, the above circuit alone still cannot resolve the problem with latches.
  - A master-slave JKFF can be used.



- The master-slave JKFF consists of two SR latches, the master and the slave.
  - The master is clocked in the normal way, while the slave clock is inverted:



- When the clock is 1, the master latch works transparently.
  - However, as the slave latch is disabled at the same time, no changes will be reflected on the output.



- The master-slave JKFF consists of two SR latches, the master and the slave.
  - The master is clocked in the normal way, while the slave clock is inverted:



- Upon the clock is changed to 0, the slave is activated to reflect the data from master to the output.
  - However, the master latch is disabled: no further changes on input will be reflected.

## **Asynchronous control**



- As well as the J, K, and clock inputs, a master-slave JKFF may also have one or two additional controls to set the state of flip-flop irrespective of clock:
  - These asynchronous controls are usually called *preset* and *clear*.

| Cl | Pr | Q         |
|----|----|-----------|
| 1  | 1  | Forbidden |
| 1  | 0  | 0         |
| 0  | 1  | 1         |
| 0  | 0  | X         |

- If Cl = 1 and Pr = 0 both master and slave are cleared to 0.
- If Cl = 0 and Pr = 1 the flip-flop is preset to 1.
- Active high on Cl and Pr will override J and K.

## **Asynchronous control**





### D flip-flop



• A negative edge triggered D type master-slave FF consists of a pair of D latches:



- Right is the symbolic diagram of DFF.
- The triangle is termed *dynamic input indicator*.



### D flip-flop



 An alternative configuration of a DFF consists of three pairs of cross-coupled NAND gates, each pair constituting a basic S'R' latch:



- The latch is stable when S' = R' = 1, Q = 0.
- To change the state, S' must make a  $1\rightarrow 0$  transition.

## D flip-flop







### JK flip-flop revisit



• The previous DFF can be modified to provide the function of a JKFF as follows:



- If J = K = 1 and Q' = 1, the input to DFF is 1, the Q outputs 1.
- Think what happens when J=1 and K=0, and vice versa.

## T flip-flop



- Finally, a T flip-flop toggles the state when input T=1 upon clock signal.
- It is simple to construct a TFF from JKFF:





• or DFF:



#### **Characteristic table**



• A *characteristic table* describes the logical properties of a flip-flop by describing its operation in tabular form.

| $\overline{J}$ | K | $Q_{t+1}$ |            |
|----------------|---|-----------|------------|
| 0              | 0 | $Q_t$     | No change  |
| 0              | 1 | 0         | Reset      |
| 1              | 0 | 1         | Set        |
| 1              | 1 | $Q_t'$    | Complement |

| $\overline{D}$ | $Q_{t+1}$ |       |
|----------------|-----------|-------|
| 0              | 0         | Reset |
| 1              | 1         | Set   |

| $Q_{t+1}$ |                         |
|-----------|-------------------------|
| $Q_t$     | No change<br>Complement |
|           |                         |

## **Characteristic equation**



• A characteristic equation describes the logical properties of a flip-flop by describing its Boolean function.

• DFF: 
$$Q_{t+1} = D$$
.

• JKFF: 
$$Q_{t+1} = JQ'_t + K'Q_t$$
.

• TFF: 
$$Q_{t+1} = T \oplus Q_t$$
.

| $\overline{J}$ | K | $Q_{t+1}$ |            |
|----------------|---|-----------|------------|
| 0              | 0 | $Q_t$     | No change  |
| 0              | 1 | 0         | Reset      |
| 1              | 0 | 1         | Set        |
| 1              | 1 | $Q_t'$    | Complement |

$$egin{array}{cccc} D & Q_{t+1} & & & & & & \\ 0 & 0 & & \text{Reset} \\ 1 & 1 & & \text{Set} & & & \end{array}$$

| T | $Q_{t+1}$ |            |
|---|-----------|------------|
| 0 | $Q_t$     | No change  |
| 1 | $Q_t'$    | Complement |